Android APP证书(.keystore)生成流程

MuYan2022-09-09web

Android 平台打包发布 apk 应用,需要使用数字证书(.keystore 文件)进行签名,用于表明开发者身份。

Android 证书的生成是自助和免费的,不需要审批或付费。

可以使用 JDK 环境中的 keytool 命令生成。以下是 windows 平台生成证书的方法:

安装 JDK 环境

可从 Oracle 官方下载 JDK 安装包:下载地址open in new window

下面以 Windows 平台,JDK 安装目录为“C:\Program Files\Java\jdk-18.0.1.1”为例,实际操作时请修改为自己安装目录

建议将 JDK 安装路径添加到系统环境变量

d:
set PATH=%PATH%;"C:\Program Files\Java\jdk-18.0.1.1\bin"
  • 第一行:切换工作目录到 D:路径
  • 第二行:将 JDK 命令添加到临时环境变量中

生成签名证书

  • 使用 keytool-genkey 命令生成证书
keytool -genkey -alias testalias -keyalg RSA -keysize 2048 -validity 36500 -keystore test.keystore
  • testalias 是证书别名,可修改为自己想设置的字符,建议使用英文字母和数字

  • test.keystore 是证书文件名称,可修改为自己想设置的文件名称,也可以指定完整文件路径

  • 36500 是证书的有效期,表示 100 年有效期,单位天,建议时间设置长一点,避免证书过期

  • 回车后会提示:

Enter keystore password:  //输入证书文件密码,输入完成回车
Re-enter new password:   //再次输入证书文件密码,输入完成回车
What is your first and last name?
  [Unknown]:  //输入名字和姓氏,输入完成回车
What is the name of your organizational unit?
  [Unknown]:  //输入组织单位名称,输入完成回车
What is the name of your organization?
  [Unknown]:  //输入组织名称,输入完成回车
What is the name of your City or Locality?
  [Unknown]:  //输入城市或区域名称,输入完成回车
What is the name of your State or Province?
  [Unknown]:  //输入省/市/自治区名称,输入完成回车
What is the two-letter country code for this unit?
  [Unknown]:  //输入国家/地区代号(两个字母),中国为CN,输入完成回车
Is CN=XX, OU=XX, O=XX, L=XX, ST=XX, C=XX correct?
  [no]:  //确认上面输入的内容是否正确,输入y,回车

Enter key password for <testalias>
        (RETURN if same as keystore password):  //确认证书密码与证书文件密码一样(HBuilder|HBuilderX要求这两个密码一致),直接回车就可以

以上命令运行完成后就会生成证书,路径为“D:\test.keystore”。

  • 注意:上述信息填写要规范,乱填有可能会影响应用上架应用市场。

查看证书信息

  • 可以使用以下命令查看
keytool -list -v -keystore test.keystore
Enter keystore password: //输入密码,回车
  • 会输出以下格式信息
Keystore type: PKCS12
Keystore provider: SUN

Your keystore contains 1 entry

Alias name: test
Creation date: 2019-10-28
Entry type: PrivateKeyEntry
Certificate chain length: 1
Certificate[1]:
Owner: CN=Tester, OU=Test, O=Test, L=HD, ST=BJ, C=CN
Issuer: CN=Tester, OU=Test, O=Test, L=HD, ST=BJ, C=CN
Serial number: 7dd12840
Valid from: Fri Jul 26 20:52:56 CST 2019 until: Sun Jul 02 20:52:56 CST 2119
Certificate fingerprints:
         MD5:  F9:F6:C8:1F:DB:AB:50:14:7D:6F:2C:4F:CE:E6:0A:A5
         SHA1: BB:AC:E2:2F:97:3B:18:02:E7:D6:69:A3:7A:28:EF:D2:3F:A3:68:E7
         SHA256: 24:11:7D:E7:36:12:BC:FE:AF:2A:6A:24:BD:04:4F:2E:33:E5:2D:41:96:5F:50:4D:74:17:7F:4F:E2:55:EB:26
Signature algorithm name: SHA256withRSA
Subject Public Key Algorithm: 2048-bit RSA key
Version: 3
  • 其中证书指纹信息(Certificate fingerprints)
  • MD5:证书的 MD5 指纹信息(安全码 MD5)
  • SHA1:证书的 SHA1 指纹信息(安全码 SHA1)
  • SHA256:证书的 SHA256 指纹信息(安全码 SHA245)
上次更新 2026/6/23 11:49:15
评论
  • 按正序
  • 按倒序
  • 按热度
Powered by Waline v2.15.8